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Information Stream Syntax for Indicating the Presence 

of a Splice Point 

This invention was made with U.S. government support under contract 
number 70NANB5H1174. The U.S. Government has certain rights in this 
5 invention. 

This application is a continuation in part of U.S. Patent Application Serial 
No. 08/864,322, filed on May 28, 1997 for a METHOD AND APPARATUS FOR 
SPLICING COMPRESSED INFORMATION STREAMS, which is herein 
incorporated by reference. 

10 The invention relates to communication systems in general, and more 

particularly, the invention relates to a method for identifying and utilizing 
splicing "in-points" and splicing "out-points" in MPEG-like information stream. 

BACKGROUND OF THE DISCLOSURE 
In several communications systems, the data to be transmitted is 

15 compressed so that the available bandwidth is used more efficiently. For 

example, the Moving Pictures Experts Group (MPEG) has promulgated several 
standards relating to digital data delivery systems. The first, known as MPEG-1 
refers to ISO/IEC standards 11172, incorporated herein by reference. The second, 
known as MPEG-2, refers to ISO/IEC standards 13818, incorporated herein by 

20 reference. A compressed digital video system is described in the Advanced 

Television Systems Committee (ATSC) digital television standard document A/53, 
incorporated herein by reference. 

A program transport stream is formed by multiplexing individual 
elementary streams which share a common time base (i.e., the same 27MHz clock 

25 source). The elementary streams comprise encoded video, audio or other bit 

streams. The elementary streams may be, but do not have to be, in a packetized 
elementary stream (PES) format prior to transport multiplexing. A PES consists 
of a packet header followed by a packet payload. As the elementary streams are 
multiplexed, they are formed into transport packets and a control bit stream that 

30 describes the program (also formed into transport packets) is added. 

There are many instances where there is a need to switch from one encoded 
or compressed bitstream to another. When switching from one compressed MPEG 
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The teachings of the present invention can be readily understood by 
considering the following detailed description in conjunction with the 
accompanying drawings, in whir.h- 

FIG. 1 shows a block diagram of a compressed bitstream splicing system 
5 in chiding the invention; 

FIG. 2 depicts a flow chart of a seamless splicing process in accordance with 

the invention; 

FIG. 3 shows a detailed block diagram of the splicer of FIG. 1; 
FIG. 4 depicts a block diagram of digital studio comprising a plurality of 
10 interoperable islands and including the invention; 

FIGs. 5A-5C depicts a plurality of splicing scenarios; and 
FIG. 6A and FIG. 6B together depict a flow diagram of a routine 600 
suitable for identifying in-points and out-points in accordance with the invention. 
To facilitate understanding, identical reference numerals have been used, 
15 where possible, to designate identical elements that are common to the figures. 

DETAILED DESCRIPTION 
The invention is generally described within the context of a digital 
television studio includes a plurality of operative environments which receive and 
process various bitstreams and which have associated switching capabilities 
20 according to the invention. The switching capabilities allow seamless or 

non-seamless splicing of a plurality of, e.g., video transport streams to produce an 
output stream. A combination of seamless and non-seamless bitstreams may be 
produced to provide a controllably degraded output stream. 

The invention is a two-input bitstream splicer which performs switching, 
25 splicing or insertion operations on a pair of MPEG-compliant input transport 
streams to produce an output stream. It must be noted that the principles of the 
invention apply to bitstream switchers or splicers having more than two inputs 
and to input streams other than MPEG-compliant input streams. The invention 
may be implemented using a general purpose computer system that is 
30 programmed to perform the functions discussed below. As programmed, the 
general purpose computer becomes a specific purpose apparatus for splicing 
digital data bit streams. 



pCT AJS98/0 1036 

WO 98/32281 f 

K «l for both seamless and non-seamless splicing of 
The .nvention mav be ***** ^ rf ^ „ t0 

^streams. Seamless ^ , continuous , ^disturbed flow of 

form . -uH«.t output stream Non . seam ,ess 
informa t,on ,e,. video or -^^^ _ have . Curbed 

spacing produces a resultant output , ances and artifacts,. For 

—on flow ( ,g„ til tt each bitstream ,s a transport 

purposes „ t this drscuss.cn, , « ^ ' It must be noted 
strea m comprising video, audi , ^ ^ 

that the invention is appbcable to p cUet ^ ^ 

0 streams. « * U -"^^ , ^ distortions in tbe spHced 
resp ect to tbe video information. fflay not 

audio and other information, since the audio 

„,w«Hne up" on a packet by packet basrs. 
temporally lineup f output-stream from a 

15 "from-stream to a to-stream ™ nt " An out-point is a place m a 

and the to-stream is ideaUy £ s J a m may be ended, 

pr esent,y-se,ected stream i.e ^ ^ ^ „ in . poin , is a place in the 

and some other stream (i.e., to-stream P her strearo . 

A "splicing segment ,s defined a P ^ 

— an in-point and as ffiany .-points and 

out-points and ,n-po n • Th^ ^ ^ ^ ^ 

out-points as possible m a stream de lay-par a meter, e.g., a 

Withm the definition of an in-point a nd an ou -point s a del y p 

■r rVRVUor MPEG compliant streams. A spncmg * 

25 vid eo buffering verifier VB, ^r ^ ^ ^ _ 

wi th a known ,n-poin ***** ^ V>M splicing segments 

known delay-parameter may include 

r:'::r:i::T;:;r:r::,.-..~..-. - 



WO 98/32281 PCTYUS98/01036 

end of the last video transport packet of the stream of interest. The video stream 
before and through the last packet must meet the splicing definition of an 
out-point. Similarly, a video stream in-point is the beginning of the first video 
transport packet of a splice segment (SS). It must be noted that other information 
5 in the transport stream, specifically audio, is unlikely to be neatly segmented at 
in-points and out-points. A method for correcting errors induced by the 
non-alignment of audio transport packets is described in U.S. patent application 
serial number 08/864,321, filed May 28, 1997, incorporated herein by reference. 

A critical aspect of splicing information streams is the proper processing of 

10 the various delay parameters. One parameter of concern is the delay parameter 
associated with the various information streams. In the case of an 
MPEG-compliant stream, the delay parameter is the video buffering verifier 
(VBV) delay parameter. Another parameter is the latency, or transitional period, 
inherent in a splicing operation. For example, a typical splice occurs at a certain 

15 time, i.e., a "splice time." Prior to the splice time an output information stream 
comprises a from-stream. At the splice time, a switch to the to-stream occurs. For 
a period of time the output stream may include information from both the 
from-stream and the to-stream. Eventually the output stream includes 
information from only the to-stream. 

20 It is assumed that the from-stream and the to-stream are each valid. There 

are certain constraints on the streams that must be met if the splicing is to be 
seamless. Seamless splicing implies that the resultant spliced bitstream will not 
cause discontinuities in the future. 

One specific example of a valid splice segment that can be seamlessly 

25 spliced is an MPEG-compliant splice segment. An MPEG Splice Segment (SS) is 
defined at the transport level and includes functionality at the video (and audio) 
levels. An information-bearing splice segment may be as short as a single frame. 
A splice segment may even be a zero frame length segment (although such a SS 
might he MPEG non-compliant). Such a zero-length segment is simply an 

30 in-point followed by an out-point (i.e., an "in-out-point"). A SS may be also be very 
long, including many GOPs. In general the length of a SS is not constrained and 
the SS should include multiple out-points to enable seamless exiting from the 
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a video disk, tape machine, or other storage device) which stores video and audio 
elementary streams and transport encodes the stored streams to produce a second 
MPEG-compliant transport stream S7. The stored information limy comprise, 
e.g., advertisement or local programming information to be spliced into the first 
5 transport stream. The splicer 300 selectively couples one of the two input 

transport streams S6, S7 to a transmitter or other subsystem as an output stream 
S9. An optional splice monitor 130 monitors various parameters of the spliced 
output signal S9, e.g., delay parameter, buffer utilization information, 
synchronization, bitstream source and the like. The optional splice monitor 130 is 
10 responsive to the controller 105 and the splicer 300. 

The splicer 300 receives the first transport stream S6, illustratively a 
television program produced by a first source, and the second transport stream 
S7, illustratively an advertisement produced by a second source. In response to a 
control signal SELECT,* the splicer produces an output signal S9 comprising 
15 either the first S6 or second S7 transport stream. The control signal SELECT 
may include priority information which causes the splicer 300 to respond 
immediately, within a defined time interval or when certain conditions exist (i.e., 
specific alignments of stream entrance or exit points). The splicer 300 produces a 
signal ACKNOWLEDGE which is used to acknowledge the SELECT signal and 
20 provide specific details about the splice operation (e.g., exact time of splice, error 
conditions and the like). The operation of the splicer 300 is described more fully 
below with respect to FIG. 3. 

The actual splicing operation is the process that takes place within the 
splicer 300 that does what is necessary to actually switch amongst the bitstreams. 
25 This involves stopping, in an orderly manner, the flow of packets from the 
from-stream; starting, in an orderly manner, the flow of packets from the 
to-stream; and adjusting the header information in the output stream. During 
some interval, packets from both the from-stream and the to-stream are likely to 
be intermixed. 

30 Splicing operations must be synchronized to be seamless. To ensure that 

input streams arrive at the appropriate splicers at the time they are needed 
several synchronizing operations may be performed. It is assumed that the 
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The decision to splice may be content related, such as a switch from a 
from-stream to a tostream when a content-related data element is encountered in 
one of the streams. For example, the from-strp.arn may be monitored and, in 
response to the detection of, e.g., a black-screen or a scene change, a splice 
5 decision may be made. This operational decision does not require 

sj^nchronization. Rather, the decision requires that the splicer (or a controller) 
analyze, e.g., the from-stream to detect the data element. The decision to splice 
may also be data-flow related, such as a switch from a from-stream to a to-stream 
on some particular packet or upon the start or stop of information flow. 

10 The decision to splice may be time-related, such as a switch from a program 

to commercial at noon. Time-related decisions must be referenced to the splicer's 
local frame-of-reference. A message-passing process passes the decision 
information to the splicer in time for the splicer to be ready to make the splice in 
its frame-of-reference. Given that the decision to splice at some time has been 

15 made, the splice will be made at the next available splice point, based upon the 
from-stream and the to-stream. 

The decision to splice may be may be event driven, such as the pushing of a 
button (e.g., the director's "take" command, as depicted in the splicer 100 of FIG. 
1). When the message indicating the event arrives at the splicer, the actions are 

20 the same as those for a time-related decision whose time has arrived. 

Some form of acknowledge message may be required. This message, when 
delivered to the originator of the splice decision (e.g., the controller), will allow an 
intelligent choice to be made about time-outs, and actions like panic non-seamless 
splices. Time-outs and determinations about corrective actions to remedy splice 

25 failures is a policy matter for the originator of the splice decision. Time-out and 
forced switch may be a service implemented by the splicer but only as a 
convenience. 

An operational unit (e.g., splicer or switcher) may feed back an appropriate 
acknowledgment message to a controlling entity. The contents of such a feedback 
30 message may include one or more of the following parameters: 1) a splice did or 
did not take place; 2) the local tirne-of-day that the splice occurred; 3; the 
delay-parameter value of the to-stream; 4) the delay-parameter value of the 
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are available when out-points occur in the from-stream. If the amount buffered is 
insufficient (e.g., more than a second elapses between successive in-points in a 
from-stream), then the buffer will overflow will contain invalid information. 
This condition is remedied by an appropriate number of in-points and out-points 
5 being inserted into the bitstreams. If bitstreams do not have in-points and 

out-points often enough, then those bitstreams can not be seamlessly spliced at 
those times. Moreover, to the extent that there is packet or cell jitter in the 
arrival time of input bitstreams, a first-in, first-out (FIFO) buffer (with output 
clocked at nominal data rate) is expected to smooth the flow. 

10 The synchronization of server generated streams will now be discussed. 

Server-generated streams must be carefully generated so that the data does not 
arrive at the splicer too early or too late. If the data arrives too early, there is 
some risk of overflow of an input buffer. If it is assumed that the splicer has 
enough synchronization buffering to hold a second or so of video, then it would 

15 seem that server streams can be delivered in any pattern of flow that never 
exceeds the just-in-time limit, and the one-second-early limit. Of course, there 
may be peak rate limitations on the splicer. 

The synchronization of remotely-generated streams will now be discussed. 
It must be noted that any stream processed in a studio containing the splicer is 

20 expected to have the same reference clock rate. Remotely-generated streams, by 
the time they have reached a splicer, should be the same as locally-generated 
real-time streams. To reference remotely-generated streams to a local master 
clock the remote source may be genlocked to the local studio. This can be done via 
a reverse channel or by locking both to an external reference, such as a timing 

25 signal derived form the Global Positioning System (GPS). If there are two 

independent studios, each with an independent master clock, and each is doing a 
remote feed to the other, then one will be delivering data too slow for the other, 
and one will be delivering data too fast. Another method is to delay a remote feed 
by a time equal to the maximum clock drift over some operating interval. A 

30 30ppm. drift rate, over 24 hours, accumulates 2.6 seconds. A six second buffer, 
initialized to a 3 second fill, is adequate to absorb clock drift. 
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and the splice will be made. It must be noted that the from-stream contains up to 
1/4 second of delay. One monitor delay later (1/2 second) the scene on the output 
monitor changes. 

If the director responded to a scene on the output monitor 132, the amount 
5 of output monitor delay (i.e., the time between the "take" command TAKE and a 
change in scene on the output monitor 132) is between 1/2 and one second. If the 
director responded to a scene on the from-stream monitor 136 , the amount of 
from-stream monitor delay is between 1/4 and 1/2 second and the output monitor 
delay is 1/2 second. If the director responded to a scene on the to-stream monitor 

10 134, the to-stream monitor 134 is continuous (i.e., no monitor delay) and the 
output monitor delay is negative 1/4 seconds (i.e., the scene changes 1/4 second 
after the "take" button TAKE is pressed and the image displayed occurred 1/4 
second prior to the press of the button). 

A second example is the "next" mode of operation. In this mode, a queued 

15 up to-stream is flushed from a to-stream synchronization buffer and the next 
segment beginning with an in-point is queued up within up to 1/4 second. The 
to-stream synchronization buffer also has zero to 1/4 seconds of random delay. 
When the in-point arrives the splice is made. 

If the director responded to a scene on the output monitor 132, the amount 

20 of output monitor delay is between 1/2 and one second. If the director responded to 
a scene on the from-stream monitor 136, the amount of from-stream monitor delay 
is between 1/2 and 3/4 second and the output monitor delay is 1/2 second. If the 
director responded to a scene on the to-stream monitor 134, the to-stream monitor 
134 is continuous and the output monitor 132 switches to a new scene between 

25 zero and 1/4 second later. 

The choice of "soonest" or "next" mode of splicing is an operational one, and 
may be based upon which disconcerting effect (delay or back-up) is least 
objectionable. To alleviate these effects an amount of delay may be inserted into 
the splicer inputs. If this delay matches the monitor delay, and the monitors are 

30 connected to the inputs of the delays, then the apparent delay between monitor 
scenes and button action is less, but the delay to final output is greater. In 
addition, a separate monitor control unit may be built to simulate the bit-stream 
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Ive with respect to the n.t bitstream examiner 31 0A and synchron,at,on 
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buffer 320A. The second bitstream examiner 310A examines the second bitstream 
for exit points which have been included in the second input bitstream S6. In the 
"selected mode" of operation, the second bitstream examiner 310E is not usuu and 
the second synchronization buffer 320B serves as a constant delay buffer which 
5 produces a delayed bitstream S3B. 

The delayed bitstream S3B is coupled to a working buffer 330B and a 
switch controller 340. The second working buffer 330B produces an output signal 
S4B which is coupled to packet switching unit 350. The second working buffer 
330B holds the selected bitstream long enough to allow for overlap of old audio 
10 packets with current video packets. This allows audio frames to continue to 

completion after a splice is made. The synchronization of audio and video frames 
are discussed in more detail below and in U.S. patent application serial number 
08/864,321, filed May 28, 1997 and incorporated herein by reference. 

A splice decision is made by a controller (e.g., controller 105) and coupled to 
15 the switch controller 340 via a control signal SELECT. Assuming that the splice 
decision equates to the command "splice seamlessly at the next opportunity," the 
switch controller 340 responds by scanning the currently selected output stream 
(i.e., bitstream S3B) for out-points. It is assumed that an in-point is positioned at 
the end of the first synchronization buffer 320A. When an out-point arrives on 
20 the from-stream, the switch controller 340 causes, via a control signal A/B, the 
switch 350 to begin coupling video packets from the to-stream through the switch 
to an optional header adjuster. At an appropriate time any audio packets within 
the to-stream are also switched. 

The optional header adjuster 360 alters time-stamps in the selected output 
25 stream S8 to produce a retimed output stream S9. The retiming of the program 
clock reference (PCR), presentation time stamps (PTS) and decode time stamps 
(DTS) of the selected stream S8.may be necessary to ensure that the splice is, in 
fact, seamless to a decoder. The header adjuster 360 includes a 27MHz (local) 
station clock 362 which is utilized by a local PCR and PCRB generator 364. To 
30 retime the presentation and decode time stamps it is necessary to partially decode 
(i.e., packetizcd elementary stream (PES) layer) the selected transport stream S8. 
The partial decoding and retiming of the PTS and DTS is performed by a PTS and 
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j 0 pT o an d DTS retimed stream 
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requirements. If the splice decision is made in the context of creating a live 
production, and the production involves information stored on servers, it is helpful 
to know that anticipated splice points are about Lo arrive soon (via, e.g., splice 
point countdowns or splicing tables). The splicing decision and related matters 
5 will be discussed in detail below. 

The invention will now be described within the context of a digital 
television studio including a number of distinct operating environments (such as 
servers or edit-suites) which receive, process and transmit various information 
streams. The operating environments, or "islands of interoperability," may be 

10 interconnected to perform one or more operations on the various information 
streams. The studio output may be delivered to end-users (e.g., the public) via 
ATSC broadcast, cable, telephone and satellite transmission and the like. The 
studio output may also be stored for later use in, e.g., a server or on CD-ROM or 
video tape. The invention is also useful in video teleconferencing and other 

15 applications. 

While the streams delivered to broadcast customers must meet, e.g., ATSC 
standards, it is not necessary to deliver all of the internal studio information. For 
example, high bit-rate studio formats are useful only within the studio or 
studio-like environments. When dealing with splicing, there may be information 

20 within the stream that is meaningless to consumer decoders, but which is 
necessary to studio splicing. 

FIG. 4 depicts a block diagram of digital studio comprising a plurality of 
interoperable islands and including the invention. The digital studio 400 of FIG. 
4 includes interoperable islands 401, 402 and 404-409. The digital studio 400 also 

25 includes a first compressed bitstream stream source 110, a second compressed 

bitstream stream source 120, a splicer 300, a controller 105 and an optional splice 
monitoring unit. The first compressed bitstream stream source 110, illustratively 
a "live feed" from a transport stream encoder, produces a first MPEG-compliant 
transport stream S6. The second compressed bitstream stream source 120, 

30 illustratively a server (e.g., a video disk, tape machine, or other storage device) 
which stores video and audio elementary streams and transport encodes the 
stores .streams to produce a second MPEG-compliant transport stream S7. The 
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An alternate mode of studio operation is to controllably operate one or more 
islands in a non-seamless mode. The non-seamless mode may be required in 
several circumstances where a splice or other transition between bitstreams must 
occur rapidly, and a range of bitstream degradation is permissible. It must be 
5 noted that non-seamless switching may produce errors which are propagated to 
subsequent islands receiving a degraded bitstream. These errors may be 
mitigated, if necessary, by. e.g., dropping damaged or inferior access units or 
groups of access units (e.g., video frames) or by adding additional access units. 
For example, if a to-stream having a short delay-parameter is to be spliced onto a 

10 from-stream with a long delay-parameter, the splicing operation is unlikely to be 
seamless (i.e., the buffer will likely overflow). In this case, frames may be 
dropped to avoid the overflow condition. Also, when a to-stream with a long 
delay-parameter is to be spliced onto a from-stream with a short delay-parameter, 
the splicer needs to adjust time stamps to cause a number of frame repeats (i.e., 

15 add frames) while the buffer fills. The buffer may also be increased by splicing 
short, all-black frames on the end of a short delay-parameter sequence to build up 
the value of the delay-parameter in current use. 

In the exemplary embodiments of FIGs. 1, 3 and 4, splicing operations take 
place in operational units (e.g., splicing islands), such as routing switchers, 

20 play-to-air switchers, production switchers or other switchers. Therefore, it is 
desirable to support a plurality of data formats and bitrates. For example, the 
so-called 422@HIGH and 420@HIGH television studio formats each support 
multiple picture formats and bit rates. Therefore, it may be necessary to splice, 
e.g., a bitstream comprising a 1280 by 960 picture element, 60Hz Progressive 

25 Scan picture onto the end of a bitstream comprising a 1920 by 1080 picture 

element, 59.94Hz interlaced picture. Moreover, it may also be necessary to splice 
a 45 Mb/s stream onto the end of a 155 Mb/s stream. 

Both of the above example splices may be seamlessly made if the streams 
being spliced have matching delay parameters. Therefore, it is important that the 

30 controller that makes the splice decision know the delay parameters of the various 
streams to be spliced. The delay parameter of a stream may be calculated by an 
operational unit receiving a stream or included within the stream as part of the 
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stream's header infoma.cn. In the splicer 300 of FIG. 3, switch controller 340 
c Les a b.tstream calculator which calculates the delay parameters of the in ut 
at S6. 87. ts should he noted that the delay parameter calculation may also 
I performed h y the bitstream examiners 31 0A, 310B or the optional sphce 

5 """"iTher critical aspect of splicing information streams ,s the determination 
of in-point and out-point locates in the streams to he sphced. To properly 
perform a seamless splice it rs necessary to find the in-point of the to-stream and 
L out-point of the from-stream. Moreover, a spl.ce segment may - 
10 in-point. and out-points having different delay-parameter values. There 
several options available for Ending the appropriate splice pmnts. 

Fi L the entire to-stream or from-stream may he analyzed by the sphcer 
in rea, time' (i.e., "on the fly",. A real-time analysis is difficult for a to-stream 
Lause an in-point cannot readily be deduced from the stream w,t out .laying 
1B the stream to its end. Even if it were known that the stream is well-behaved the 
ZZ of an I-frame is not known in advance. By the time the first I-frame has 
endtd, and its length is known, it is probably too late for the informal to be 
, us ed It must be noted that this problem may be overcome by using, e.g., a more 
powerful computing device. A real-fme analysis is easier for a from-stream 
20 because the delay-parameter of the from-stream is known (from the in-poin or 
otherwise,, the presentation time-stamps in the stream indicate when frames 
,eave the decode buffer, and bit-counts (or packet counts, indicate when the 
frames enter the decode buffer. The frame rate is also known from sequence 
headers. With the foregoing information it becomes possible to calculate, at the 
25 start of a new frame, that the preceding video has .eft the buffer in an out-po.nt 
status. This information arrives only a little bit late. 

Second, an external table may be created to contain indications of where 
splice points are. This approach assumes that the information about in-point and 
out-point locations has been computed eisewhere (e.g., during a stream encoding 
30 process,. This approach rec,u,re S that the ,„-po,„ts and out-po.nts be indexed ,„ 
some manner (e.g.. Nth packet from a marker, first packet after a Ume-of-dny 
reference, and the like,. This approach also requires the updating of a splice table 
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associated with an information stream as the information stream is processed, 
and the transmission or regeneration of the table as the information stream is 
transmitted (e.g., via satellite link). It should uc noted thai the use of separate 
information tables to determine splice locations is practical within a server or 
5 island of operability, though this use of tables may be less practical when 
transmission encoding and decoding are to be performed on the stream. 

Third, in-point and out-point markers may be placed within the 
information stream directly. An MPEG compliant information stream includes 
header portions where such a marker may be included. There are header portions 

10 suitable for in-point and out-point marker insertion at the system level, transport 
level and PES level. There are also opportunities to insert markers in the 
elementary streams. 

Both in-points and out-point should be marked and, ideally, the marking 
should occur at the system, transport and PES levels. In addition to the insertion 

15 of in-point and out-point markers, the delay-parameter associated with the 

stream or splicing segment and an audio offset (i.e., a displacement of audio-frame 
boundaries from associated video frames) should also be inserted into one or more 
layers of the information stream. The MPEG count-down feature should also be 
used to indicate that, e.g., an out-point is approaching (decreasingly positive 

20 countdown) or an in-point has been transmitted (increasingly 

negative-countdown). For various business reasons it may be desirable to remove 
these markers prior to transmitting an MPEG or ATSC signal to an end-user (i.e., 
consumer). While end-users might want to splice the video, it is important that 
they not be able to clip out commercials automatically. 

25 The above-described redundancy of marking provides a maximum 

flexibility to system designers and provides a redundancy of operation which helps 
to ensure that splicing operations are, in fact, seamlessly made (i.e., made at 
appropriate in-points and out-points). 

Bitstream Generation 

30 To help ensure seamless splicing it may be necessary to create the 

bitstreams to he spliced in a certain manner. There are two facets to the creation 
of bitstreams that can be spliced; the creation of the stream content, and the 

Zi 
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• ,on of appropriate splice centre! Ration Cc in-point and out-pent 
Z TJpHCtv. assume that a de.red value of the delay-parameter 

ade 1 an cation of bits among frames must be done to assure that a decoder 

z:, ~. a « — nt - - - ^ r 

frames arranged in the following display order. ...IBBPBBPBB 
"prLch is straightforward a the expense of unnecessary degraded picture 
ouality For example, a scene cut on the last P frame of an 

BBPBBPBBPBBP..." GOP would be reproduced with a very small bi budge, 
" . , rnp struct ure that is ideal for all appl.cations. 

Unfortunately, there is no single GOP structure tb unaccept able. 
Moreover, the loss of flexibility implied in this approach is probably unacce pta 

insertion of in-points at out-points at predetermined time intervals 

seconds respectively). This approach does not reouire the use of a specific GOP 

Zcture, therefore the encoder is free to select frame type based upon the input 

25 PiCtOT There are various rate-control issues to be resolved when switching 
between MPEG streams or splice segments. As such, it may be necessary to 

Iain the contents or si.e of, e.g., coded picture bitstreams. One rate-contro. 
HI involves the amount of data transmitted to a decoder buffer. Por examp e, 
lne decoder buffer will not overflow if the buffer contents (measured ,n 
30 any out-point is less-than-or-e.ual-to the decoder buffer contents ,meas ured ^ 
bits, measured at the most recent m-point. It is not necessary to .now t o nU.u,l 
number of bits, it is on,y necessary to ensure that the number of b.ts ,n the 
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decoder buffer does not increase from in-point to out-point. It must be noted that 
so-called "stuffing bits" are not counted, since these bits are only included to meet 
specified transmission rates and disappear from Hit; buffer when the real bits are 
used (i.e., stuffing bits do not accumulate in the buffer). 
5 Another rate control issue involves the presentation time of decoded 

information frames in relation to the time the buffer receives the next frame. For 
example, the decoder buffer will not underflow if, at an out-point, the time 
(measured in time units) to display the not-yet displayed buffer contents is 
greater than the time (measured in time units) for the first I-frame to be delivered 
10 to the decoder at the specified bit rate. In other words, the next I-frame (the first 
frame of the to-stream) must be delivered to the decoder buffer before the buffer is 
emptied. 

The above-described amount of time may be defined at the 
"Delay-Parameter" for the stream. The frame sizes (measured in time to transmit 

15 the frames at the operating bit rate) must be consistent with the operating delay 
parameters to ensure seamless splicing. The delay parameters are the end-to-end 
VBV size (measured in time) and the VBV contents (measured in time) at the 
beginning/end of a stream. An additional, globally defined value is the maximum 
size of physical buffers (in bits). This maximum size must be greater than the 

20 maximum VBV size implied by the MPEG profile and level indication criteria. 
Finally, the decode time stamp at an out-point of a from-stream should be one 
frame time of the stream greater that the DTS and PTS of the last frame of the 
from-stream. 

As previously mentioned, it is important to distinguish between a splicing 
25 decision and the actual process of splicing. A splicing decision is made by some 
human. The decision may be made in the process of generating a list of 
programming to be transmitted by a television studio or in real time as the studio 
is transmitting. The splicing decision may be made by some surrogate process, 
such as a preprogrammed command to splice a station identification 
30 announcement into the studio transmission every day at 12:05 AM. The decision 
may be to splice at a particular time in the future or immediately. 

21 



PCT/US98/01036 

WO 98/32281 

♦ of the streams to be spliced may be known at the time 

*t the time of insertion), 
transmitted at the urn operational unit 

A decision contains the following elements. Fust, the op 

.«a 3 e The now decision may arise from direct human actum (e.g., 

ress, or some external — ng process dec^g to^ nda sp ce-no„ 
u message. The logica, condition may be the occurrence of a - ^ ^ 
SMPTE) in a parties information stream, _ . 

video or audio stream, a reference tame (e.g., PCR) m an 

20 appropriate streams for splicing. tM t0 the appropriate operational 

After a decision is made it is communicated to the appropr v 
uni t Sin a there is a possibility of errors (e.g., due to the complexity of combining 

TP ici g process closely and adapt to error conditions and other condition, 
25 I a result of the decision, and part of making the sphce work >s the 

operational unit at the correct time. This is a function of overal. system 
option, and may involve synch— of information How from a serve 
t L .witch,. After rece.v.ng the splicng decs.on the spUcer w,„ make 
30 The process of seamless splicing recmres that the to-stream i. entered at an 

Lplt. the from-stream is exited at an outfit and, possib.y, the management 
of one or more buffer and timing parameters. 
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Illustrative Examples of Video Splicing 
The above-described concepts will now be illustrated using several 
ftvamnl.es of MPEG bitctrcam splicing uperaLions. The first example is an all 
I-frame low delay splicing example. A to-stream comprises either 24 or 30 frames 
5 per second (fps) video streams including only I-frames. The delay parameter of 
the to-stream is equal to one frame time at the slowest frame rate (i.e., 42mS if 24 
fps). In this example each of the I-frames contains fewer bits than can be sent in 
one unit of display time (i.e., one 42mS frame time) at the bit rate for the frame. 
If the bit rate is 150 Mb/s, a 30fps frame contains no more than 5 Mb. If the bit 

10 rate is 150 Mb/s, a 24fps frame contains no more than 6.25 Mb. 

When the last bit of a from-stream having the same parameters has 
entered a decoder buffer, the presentation time stamp indicating when the last 
frame is to be presented has a value 42mS in the future. Thus, if the from-stream 
were at 30Hz. (33mS frame rate), , 9 ms. after the out-point the last frame of the 

15 from stream will be taken from the decoder buffer, and 33mS later the first frame 
of the to-stream will be needed. If the to-stream is also 30Hz, the first frame will 
have been delivered 9mS before it is needed. If the from-stream were at 24Hz, 
and the to-stream were also at 24Hz, the to-stream frame arrives just in time. If 
the from-stream were at 60Hz, (17mS) then when the last bit of the from-stream 

20 is delivered, the decoder buffer contains 2 frames (33mS) and the decoder will not 
use the first of them for 9mS. If the bit-rates of the from and to sequences differ, 
as long as the bits are delivered at the rate corresponding to the sequence bit-rate, 
the time to load frames remains correct. To summarize, streams are coded with a 
bit-count between the in-point and following out-points that is calculated from the 

25 bit-rate and the frame-time (i.e., bit-rate * frame-time). The presentation 

time-stamps are set to values that all agree with the delay-parameter (i.e., first 
frame presented delay-parameter after the first bit arrives.). 

The second example is a complex GOP transmission format. For purposes 
of the second example, it is assumed that stream is a 30 frame per second video 

30 (and associated audio) stream having delay-parameter of 250mS, a display order 
of "...IBBPBBPBBPBBPBBP...' and transmission order of 

"...IPBBPBBPBBPBBPBB..." (where "I" represents an I-frame, "P" represents a 

IS 
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P frame and "B" represents a B-frame, This GOP structure deludes ,n-po,nts on 
^ frames and out-po.nts on the frame ,mmed,atel y preced.ng the I*ames. At 
, t Tent the PTS associated with the iast P frame U 250mS in the future. 

It must contain less than 25 0mS worth of b,ts. Th. vai.d-MPEG constant 
Llhes that the P-frame fo„ow,ng the I frame also doesn, 
necessar v that the I-frame use a„ 250mS. If the I-frame does u e a»r 25 ms t 
next P-frame must use less than 33mS .i.e., if the I-frame used 230 ms, 
P.frame would be perm.tted. though not required, to use 53mS>. 

The th,rd example is a multiple output example. For purposes of th, d 

audio , stream having the following GOP structure: pOTII>ppp „ The 

■ IPP PPPPPPPPPPPPPPPPPP™ PPPPPPPPPPPPPPPPPIPPPP - 
strea m ,s also assumed to have a de,a,parameter of 2 5 0mS and a transmission 
18 bit rateof20Mb/s(,.e., 670Kb per frame,. If an 1-frame takes 231mS 

Is 2 0mS then, after !6 frames, the decoder buffer contents have subs, ed to a 
H below the leve, at the ,n-point to the stream. This mav he calculated us,n g 

an equation such as the following: 

(231 + 20N)= 33*(N+D 
20 The above equation represents the time for hits entering, starting with an 

I-frame, 23lmS worth of data, followed bv N 20mS P-frames, being equate to 
the time for the same N + ! frames-worth of bits to be taken from the buffer N + l) 
frames, each taking 33mS. In th,s example each I-frame mav he an ,n-po,nt and 
all the P-frames after the fifteenth P-frame may be out-po,nts. 
25 ThedecoderbulTerreactsasfollows. At the sp.ice point, the buffer contams 

7 frames and a presentation time stamp indicates that the last frame is to he 
presented in 250 m S. The 7 frames each use 20,33 of the bits/frame quota <,,, 
each P-frame frame is 400 Kb and the buffer contains 2.8 Mb,. Over the next 
frames, the Lframe comes in, .ncreas.ng the buffer contents. Since each I-frame 
30 adds 670Kb and each P-frame taken out removes 400Kb the buffer conta.ns 
4.7Mb after the seven P-frames are taken out. The .-frame is then pr«on*d. 
removing 4.6Mb from the buffer and, therefore, ,eav,ng 100Kb in the bufle,. The 
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delay in the buffer is approximately zero. Each P-frame now adds 400 Kb in 
20mS and every 33 ms 400Kb is used. Thus, delay in buffer increases by L3mS 
every frame time After 15 frames, the delay stored in the butter has reached the 
delay-parameter value. At this time a splice to another sequence may be made 
5 because the buffer is able to receive an I-frame. 

Compressed Audio Splicing 
The following discussion of splicing of compressed audio is limited to the 
issue of splicing combined video-audio streams in the audio-follows-video mode. 
The composition of streams from separately edited audio and video streams is not 
10 considered here. 

Compressed audio is carried in frames. Each audio frame is of fixed 
duration and contains a fixed number of bits. Unfortunately, the audio frame 
size, or duration, is different from any of the video frame sizes, or durations. This 
means that audio frames will not align with splice points. Audio frames can be 
15 considered to be randomly aligned with the video. Therefore, when making a 

splice, the alignment of the audio with the video will be different for the to-stream 
and the from-stream. 

It is desirable to ensure alignment of audio information to corresponding 
video information (i.e., "lip-sync"). That is, the audio and video must remain 
20 properly phased with respect to each other. A Presentation Time Stamp (PTS) 
exists in each audio stream. The audio and video PTSs refer to the same 
reference to allow the required synchronization. When the splice is complete, the 
to-stream becomes the output stream. It is important to note that, particularly 
due to audio constraints, the process of switching may extend in time before and 
25 after the actual switch instant. 

Audio information frames in an information stream are ideally located 
within a limited time difference from respective video information arrival at the 
end of the decoder buffer. If there is a 1/2 second end-to-end video buffer delay, 
then audio packets should be approximately 1/2 second later in a transmission 
30 stream than corresponding (i.e., having the same presentation time stamps; video 
packets. If this assumption is correct, then the switching operational unit must 
save audio information from the from stream for this 1/2 second after the video 
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*• ,o fnr 1/2 second after the splicer has 
•«. i The source stream must continue tor VI secona 
^ Jl — _ U U - — g * —ate rapid 

. , v KmVpn This is not the most desirable 
5 overlapped audio packets may simply be broken. Th s ^ 
»„ or oach because it relies upon the CRC to prevent the use of par 
app.oachbec packe ts/second, every few 

the CRC fails one time in 64Kpacke s, when a broken-packet 

thousand seconds there is a potentia undetected er ^ ^ 
CRC fails it fails every time the packet is used. This means tha 

^ I co d abroach » splicin, audio is to include "unfinished" from-stream 
au d,o fries «.e hose overlapping a video sp.ice, in the resultant stream. The 
I e l au io f ames are then retimed such that they butt up against the 
to-streamau This technique assures continuous aud>o 

15 "unfinished" from-stream audio fram e. ~ , ^ ^ ^ 

at the expense of continuous inspection, buttering an 

I packets The first complete to-stream audio frame is se.ected as the fi st 
and packets. „ tVie to stream frame which has already started is 

audio frame to play because the to-stream „ trt)m . frame . 

likely to be delayed too much to match the end of the unfinish 
20 This technique also causes a slightly distorted lip-sync. 

A third approach to splicing audio is to maintain alignment of audio with 
its corresponding video, that is, to leave a gap between the end of the from-stream 
audio frame and the beginning of the to-stream audio frame. This approach 
advantageously relies on the MPEG decoder specification which requires that 

26 audio frame gaps are muted. amount apphed to 

presentation-time-stamps are adjusted by the same aaj 

Z video frames. In this manner Hp sync is maintained. The third approach ,s 
especially useful when many splices .e.g., the creation of a sequence from a 
succession of short sp.ice segments, may produce audio artifacts due to the 



30 muting. 
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FIG. 5 depicts a plurality of splicing scenarios involving audio alignment 
which illustrate aspects of audio-video splicing, assuming the above cited third 
approach is used to maintain alignment of audio with its corresponding video. 

FIG. 5A depicts the simple splicing case where both audio streams align 
5 with their corresponding video. The splicer delays both to-streams and simply 
switches at the splice point. 

FIG. 5B depicts the splicing case where the from-stream video and 
from-stream audio are aligned, but the to-stream video and to-stream audio are 
not aligned. When the splice is made, a partial to-stream audio frame is 
10 discarded. The next complete to-audio frame is passed to the output with 
appropriate delay. 

FIG. 5C depicts the typical splicing case where both audio streams do not 
align with the corresponding video streams. It can be seen that a from-stream 
audio frame has already begun before the splice point. This audio-frame is 

15 buffered and transferred to the output. It doesn't end until some fraction of a 

frame time after the splice. The to-stream audio frame that spans the splice-point 
cannot be used. The next to-stream audio frame also cannot be used. It begins 
too early, and would overlap the last from-stream audio frame. The first 
to-stream audio frame that appears in the output stream begins D time units 

20 after the splice-point. This delay may be as much as two audio frames. 

In the above example (FIG. 5C) the lip-sync is preserved, but as much as 
32mS of from-stream audio overlaps the to-stream video. Also, the first to-stream 
audio begins as late as 64mS after to-stream video begins. Finally, the splicer 
performing the splicing operation must buffer a whole audio frame in each work 

25 buffer. 

Ideally, every audio frame includes a PTS. It is possible that some 
equipment manufacturers only include a PTS every, e.g., third audio frame. In 
this case, or the case where there is no audio PTS, a splicing operation may be 
performed after calculating a virtual time-stamp. The virtual time stamp is 
30 derived from the approximate real-time delay of audio-frames from video 

reference time-stamps. The virtual audio-time-stamp is then incremented by the 
(known) audio-frame duration on successive audio-frame starts. This process may 

IS 
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streams to not 

theSWdi0 ' ^ai^^ 38 Thlsdata ,s usually 

MPEG streams. i nib ua 
•r rv data is included in many wir By contrast, a 

Auxihaiy data un known length, cy 

operation, induflng: « ' an d J through . separate path to, ,,, a 

the video data; 2) insert ***** da or other 

consumer-related a*^* in etchers to keep segn—n 

15 auxdiary data and rely upon hese ^ ^ „ d 

Mrre ct (this quires Knowledge ab»t the c ^ ^ ^ d ta 

*. len^s o f apiary data se^ « - ^ may be . para me er 



corrc^ v—- * within tnose »^ 

the lengths of auxiliary data ^ ^ fee . pararoete r 

. w^^^"^^<***~. Theauxiharydatamaybe 
passed to the switcher by a deasvon on the auxiliary-data 

inp ut may be buffered and inserted »to the P ^ ^ ^ system 
Jsis as a replacement f or null pac^ ^ to provlde chann el 

UM ,s responsibiHty to ah g n such da. ^ ^ stream data ra te. 

capacity for .nserted aux-da a ^^^^^^ 

Various header fields wttan P ^ header 

packets are used to ,nd,cated the presen o sp c , ^ ^ ^ 

Lrmation compnse, e.,, a ^ „ , in4lcates that a 

5 p llc e_countdown field. The ^ - fieW , s an 8 . h ,t .nte.er 

30 splice.countdown field » P-^ J' " " siream packels re ma,n,n 6 unul a 

splicing point is reached, 
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a 4-bit field used to derive splice_decoding_delay and max_splice_rate data from, 
e.g., a table storing such data. The standard use the these header flags and fields 
tn implement a splicing function is defined in the MPEG specification. 

As previously discussed, splice points within a transport stream may be in- 
5 points, out-points or both. An out-point is equivalent to the MPEG-definition of a 
splice point. An in-point comprises a splice point (i.e., an out-point) followed by a 
sequence header that is immediately followed by an I-frame. Therefore, in-points 
within a particular stream may be identified by finding out-points followed by 
sequence headers that are followed immediately by I-frames. Thus, a to-stream 

10 may be entered at any in-point, as described above, even if the out-point of a from- 
stream is not followed by a sequence header or an I-frame. In this embodiment, 
the splicing_point_flag of the packet immediately preceding the out-point must 
equal one, and the splice_countdown field of that packet must equal zero. 
However, the above-described embodiment requires that the bitstream be parsed 

15 down to the elementary layer to examine, e.g., the picture_coding_type field in the 
picture header to determine if an I-frame is present. 

In the preferred embodiment of the invention, entrance and exit indicia 
comprise information residing within the transport layer, thereby obviating the 
need to parse the bitstream down to its elementary layer. Specifically, an out- 

20 point in a from-stream is indicated by the splicing_point_fiag being equal to one 
and the splice_countdown field being equal to zero. Similarly, an in-point in a to- 
stream is indicated by the splicing_point_flag being equal to one and the 
splice_countdown field being equal to negative one. Thus, an in-point packet (i.e., 
the packet that immediately follows an in-point) and an out-point packet (i.e., the 

25 packet including an out-point) may be the same packet. Moreover, the splice_type 
of an in-point packet (i.e., the packet that immediately follows an in-point) 
indicates the suitability of splicing the in-packet to an out-packet in that the in- 
packet and the out-packet should both have the same splice_type. 

In this embodiment, an out-point that is not also an in-point must have 

30 the splicing_point_flag equal to zero in the packet immediately following the 

packet with the splicing_point_flag being equal to one and the spliGe_countdown 
being equal to zero. In this manner, the splicing_point_flag indicates that the 

31 
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out point .s not associated with an in-point. This is because the 
p l g po.nt.fla, must he eo.ua. to one for the contents of the sphce_countdow„ 
tl to o! va„d, and the sphce.countdown field must he valid and eoual to 

negative one for an in-point. 
. The ahove descnbed embodiment of indicia for identifying ,n-points (,..., 

' „ indicia, and out-points <i,, exit indicia, within an MPEG-H.e bitstream 
provides several advances. One advantage, as previously described . the 
ahiiitv to identify ,n-points and out-po.nts by parsing only the adaptation header 
of the transport layer, and avoiding the parsing of the elementary aye, 

bother advantage of the preferred embodiment is that each transport 
packet is self contained in the sense that each packet contains sufficient 
nformation to determine if the particular packet comprises an m-point an out- 
point or hoth. This aUows the identification of an in-point or out-point in a packet 
without regard to any previous packets. Thus, there , no need to, e,. co.pa e 
15 thesplice type fl eldofaprobablein-pointpackettothesplice_typefleldofthe 
Lding'packet before determining that the probable in-point packet -s 
an in-po" packet. However, it must be noted that the s P ,ice_type field indicates 
the suitability of splicing the parttcular stream and another stream assorted 

with another splice_type field. . .... 

20 As previously mentioned with respect to bitstream generation, it is 

desirable to generate bitstreams according to the in-point and 0— sy^ax 
described above. Specifically, it is desirable to include entrance and exit indicia 
many places within the bitstream, illustratively, at every I-frame during the 
bitstream encoding process. To accomplish this inclusion of entrance and exit 
25 indicia, the transport multiplexer used to generated the transport stream o be 
subsequently spliced must be provided with information identify.ng packets 
associated with, e.g., 1-frames. Alternatively, an elementary stream parsing to 
identify appropriate entrance and exit points within a stream may be 
implemented. 

,„ FIG 6 dep,cts a flow diagram of a routine 600 suitable for identHy.ng 

,n-points and out-po,nts in accordance with the invention. Specficaliy. the 
routine BOO suitable for use by, illustratively, the bitstream examiners 310A 
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and 310B of the splicer 300 depicted in FIG. 3. The routine 600 is entered at step 
605 when a transport packet within a stream to be examined (e.g., S6 or ST) is 
rpr.eivp.H hy, e.g., a bitstresm examiner fe.g., 310A ur 3IGB V ;. The routine 600 
proceeds to step 610, where the packet header of the received packet is examined, 
5 and to step 615, where a query is made as to whether the splice_point_flag within 
the adaptation header of the received packet is equal to 1. 

If the query at step 615 is answered affirmatively, the routine 600 proceeds 
to step 620, where a query is made as to whether the splice_countdown flag is 
equal to 0. If the query at step 620 is answered affirmatively, then the routine 
10 proceeds to step 635, where the packet is identified as containing an out-point. 
Such identification may take the form of setting an "out-point-ready" flag suitable 
for use in, e.g., step 210 of the routine 200 of FIG. 2. The routine then proceeds to 
step 635, where it is exited. 

If the query at step 620 is answered negatively, then the routine 600 
15 proceeds to step 630, where a query is made as to whether the splice_countdown 
flag is equal to -1. If the query at step 630 is answered affirmatively, then the 
routine proceeds to step 640, where the packet is identified as containing an in- 
point. Such identification may take the form of setting an "in-point-queued" flag 
suitable for use in step 208 of the routine 200 of FIG. 2. The routine then 
20 proceeds to step 645, where it is exited. 

Although various embodiments which incorporate the teachings of the 
present invention have been shown and described in detail herein, those skilled in 
the art can readily devise many other varied embodiments that still incorporate 
these teachings. 
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What is claimed is: 

, A method for identifying one of entrance indicium and exit indicium in an 
MPEG-like transport packet, said entrance indicium being associated w,th a 
disport packet su.tab.e for use as a first packet in a splicing segment sa.d „t 
ZL being associated with a transport packet suitable for use as a last packet 
in a splicing segment, said method comprising the steps of: 

examining C610) . valid splice countdown field within a portion of a 

transport packet; wherein: 

said entrance indicium is identified (630) by said splice countdown 

field being equal to a first value; and 

said exit indicium is identified (620) by splice countdown field being 

equal to a second value. 

15 2 . The method of claim 1, wherein said first value is negative one and said 

second value is zero. 

. 3 The method of claim 1, wherein said splice countdown field is only valid if a 
sphce point flag within said portion of said transport packet is e q ual (615, to one. 

4 In a system for generating an MPEG-like transport bitstream in response 
to one or more elementary streams, a method for including one of an entrance 
indicium and exit indicium in one or more MPEG-like transport packets, said 
entrance indicium being associated with a transport packet suitable for use as a 
25 first packet in a splicing segment, said exit indicium being associated with a 
transport packet suitable for use as a last packet in a splicing segment, said 
method comprising the steps of: 

identifying packets suitable for use as first or last packets in a spl.cng 



20 



segment; and 



30 



setting to a first value a splice point flag within a header portion of each of 
said identified packets to include said entrance or exit indicium; and 
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setting to a second value a splice countdown field within said header 
portion of said identified packets to include said entrance indicium, and setting to 
a third value said cplicc countdown field willim said header portion of identified 
packets to include said exit indicium. 

5 

5. The method of claim 4, wherein said first value is one, said second value is 
negative one, and said third value is zero. 

6. The method of claim 4, wherein said entrance indicium is associated with a 
10 packet the precedes a sequence header that immediately precedes, in the case of a 

video stream, an I-frame. 

7. A method for splicing bitstreams, said bitstreams comprising a plurality of 
information segments representative of a sequence of information frames, said 

15 method comprising the steps of: 

monitoring (210) a first bitstream to detect an exit indicium, said first 
bitstream being coupled to an output and including at least one of said exit 
indicium, said exit indicium indicative of an appropriate last information segment 
of a splicing segment; 
20 providing a second bitstream, said second bitstream including at least one 

entrance indicium, said entrance indicium indicative of an appropriate first 
information segment of a splicing segment; and 

coupling (220) said second bitstream to said output in response to a control 
signal, a detection (620) of said exit indicium in said first bitstream and a 
25 detection (630) of said entrance indicium in said second bitstream; wherein 

said exit indicium comprises a valid splice countdown field in said header 
portion of said information segment being set to a first value. 

8. The method of claim 7, wherein said first value is zero. 

30 
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„ The method of claim 7. wherein sa,d entrance indicium comprises a valid 
sp ,ice countdown field in said header po, Uon of said transport packet being set to 

a second value. 

5 10 . The method of claim 7 wherein said step of monitoring said first bitstream 

comprises the steps of: 

examining (615) a splice point Hag within a header portion of each 

information segment; and 

in the case of said splice point flag being set to a third value, examining 
10 (630) said splice countdown field in said header portion of sa.d information 
segme nt, said entrance indicium comprising sa.d splice countdown field being 

equal to a second value. 

U An apparatus for identifying one of entrance indicium and exit indicium in 
15 an MPEG-like transport packet, said entrance indicium being associated with a 
transport packet suitable for use as a first packet in a splicing segment said exrt 
indicium being associated with a transport packet suitable for use as a last packet 
in a splicing segment, said apparatus comprising: 

a bitstream examiner (310A; 310B), coupled to receive said information 
20 stream, for examining (610) a valid splice countdown field within a portion of a 

transport packet; wherein: 

said entrance indicium is identified (630) by said splice countdown 

field being equal to a first value; and 

said exit indicium is identified (620) by splice countdown field being 

25 equal to a second value. 

12. The apparatus of claim 11, wherein said first value is negative one and said 

second value is zero. 

30 13 The apparatus of claim 11, wherein said splice countdown field is on!y valid 
if a spl.co point fiag within said portion of said transport packet is equal ,«15, to 
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14. The apparatus of claim 11, wherein said bitstream examiner generates an 
output signal (S2A; S2B) indicative of said une of said entrance indicium and said 
exit indicium. 

15. The apparatus of claim 14, further comprising: 

a utilization circuit (320A; 320B), coupled to said bitstream examiner, for 
processing said bitstream in response to said bitstream examiner output signal. 
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